Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: global vars #1039

Merged
merged 3 commits into from
Jan 15, 2025
Merged

feat: global vars #1039

merged 3 commits into from
Jan 15, 2025

Conversation

kellyjosephprice
Copy link
Collaborator

@kellyjosephprice kellyjosephprice commented Dec 9, 2024

PR App Fix RM-11562

🧰 Changes

Allows user variables in esm code.

Prior to this, user variables (eg {user.email}) were being replaced with a JSX component (<Variable name="email" />) opaquely. The actual values were provided by the VariableContext. This mimiced how they were handled in pre-mdx versions of the library. This PR undoes that, and provides the user object as a top level import. The following was not possible before, but is possible now:

export const HelloWorld = () => {
  return <div>{user.email}</div>
}

We had talked about implementing it this way, and I somehow ignored/forgot that. Oops.


The VariableContext is still being used, because our custom wrapper around code blocks will also insert the user object into the scope of the code block. eg:

```
Why do we support this? {user.email}
```

Also, I've left the variable transformer processor/transform/variable in place, because it's still being used by the editor. When calling mdast, user variables such as {user.email} should show up as a readme-variable node type.

🧬 QA & Testing

@kellyjosephprice kellyjosephprice marked this pull request as ready for review December 9, 2024 21:12
Copy link
Member

@trishaprile trishaprile left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

ty for the tests

@kellyjosephprice kellyjosephprice merged commit ecb7f61 into next Jan 15, 2025
13 checks passed
@kellyjosephprice kellyjosephprice deleted the feat/global-vars branch January 15, 2025 23:08
rafegoldberg pushed a commit that referenced this pull request Jan 22, 2025
## Version 7.12.0
### ✨ New & Improved

* add exports ([#1044](#1044)) ([bf9ed34](bf9ed34))
* global vars ([#1039](#1039)) ([ecb7f61](ecb7f61))

### 🛠 Fixes & Updates

* add exports util with tests ([#1045](#1045)) ([e5180a4](e5180a4))

<!--SKIP CI-->
@rafegoldberg
Copy link
Contributor

This PR was released!

🚀 Changes included in v7.12.0

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants